//一只青蛙一次可以跳上1级台阶，也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
//
// 答案需要取模 1e9+7（1000000007），如计算初始结果为：1000000008，请返回 1。
//
// 示例 1：
//
// 输入：n = 2
//输出：2
//
//
// 示例 2：
//
// 输入：n = 7
//输出：21
//
//
// 示例 3：
//
// 输入：n = 0
//输出：1
//
// 提示：
//
//
// 0 <= n <= 100
//
//
// 注意：本题与主站 70 题相同：https://leetcode-cn.com/problems/climbing-stairs/
//
//
//
// Related Topics 记忆化搜索 数学 动态规划 👍 393 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
function numWays(n: number): number {

    //? dp[i]表示跳到i级台阶有多少跳法 dp[i] = dp[i - 1] + dp[i - 2]
    const MOD = 1000000007
    const dp : number[] = new Array(n + 1).fill(0)
    dp[0] = 1
    dp[1] = 1
    for (let i = 2; i <= n; i ++) {
        dp[i] = (dp[i - 1] + dp[i - 2]) % MOD
    }
    return dp[dp.length - 1]
};
//leetcode submit region end(Prohibit modification and deletion)
